草庐IT

python - 非阻塞python进程或线程

全部标签

ruby - 为什么退出 Ruby 线程会杀死我的整个程序?

我有这段代码:puts"Start"loopdoThread.startdoputs"Hellofromthread"exitendtext=getsputs"#{text}"endputs"Done"我希望看到“Start”后跟“Hellofromthread”,然后我可以输入会得到回显的输入。相反,我得到“Start”和“Hellofromthread”,然后程序退出。来自关于exit的文档:Terminatesthrandschedulesanotherthreadtoberun.Ifthisthreadisalreadymarkedtobekilled,exitreturnst

ruby - 如何在 ruby​​ 中使用反引号开始子进程的连续输出

我有一个ruby​​应用程序,它使用反引号将ant作为子进程执行。这没有任何问题。当我执行putant时,ruby等待子进程ant完全完成,然后将输出打印到标准输出。如何让ruby​​连续打印子进程的输出? 最佳答案 你可以使用IO.popen。IO.popen("ant")do|output|whileline=output.getsdo#...maybeputsline?somethingmoreinteresting?endend 关于ruby-如何在ruby​​中使用反引号开始子

ruby - Ruby 进程如何限制其 CPU 使用率?

假设我希望Ruby进程使用的CPU不超过15%。是否可以?怎么办? 最佳答案 您可以尝试使用Process.setrlimit来自标准核心:Setstheresourcelimitoftheprocess.这看起来只是setrlimit的包装器来自C库,因此它可能仅在Unix-ish平台上可用。setrlimit不支持CPU百分比限制,但它支持以秒为单位限制CPU时间。如果您只是想让您的Ruby进程不占用整个CPU,那么您可以尝试使用Process.setpriority来调整它的优先级。这只是libc的setpriority的包装

ruby-on-rails - rb_gc() 上的跨线程冲突

我正在处理的代码库最近从Ruby1.9.2升级到Ruby1.9.3,从Rails3.1升级到Rails3.2.2。因为我使用的是RVM,所以我只是简单地执行了rvminstall1.9.3,我原以为这是所有必要的。当我运行时railss我得到了错误[BUG]cross-threadviolationonrb_gc()我找到了许多与此问题相关的链接。有oneonStackOverflow,但它并没有真正给出答案。最有希望的答案是ontheRVMsite:IneverycaseofthisIhaveseenthusfarithasalwaysendedupbeingthatarubygem

Ruby 线程和变量

为什么结果不是从1到10,而是只有10?require'thread'defrun(i)putsiendwhiletrueforiin0..10Thread.new{run(i)}endsleep(100)end结果:1010101010101010101010为什么循环?我正在运行while循环,因为稍后我想一直遍历数据库表并回显从数据库中检索到的任何记录。 最佳答案 传递给Thread.new的block实际上可能在将来的某个时间点开始,到那时i的值可能已经改变。在您的情况下,在所有线程实际运行之前,它们都已增加到10。要解决此

如果进程以参数开始,Ruby readline 会失败

我遇到了最奇怪的问题。下面的代码可以正常工作:require'json'require'net/http'h=Net::HTTP.new("localhost",4567)while(l=gets.chomp!)res=h.post("/api/v1/service/general",l)putsres.bodyend但是,通过从参数获取主机/端口的小修改:require'json'require'net/http'h=Net::HTTP.new(ARGV[0],ARGV[1])while(l=gets.chomp!)res=h.post("/api/v1/service/genera

ruby-on-rails - EventMachine 和 Ruby 线程——这里到底发生了什么?

我们将Rails和EventMachine一起使用,当与Passenger一起使用该组合时,需要进行一些非常具体的设置。经过大量的试验和错误,我让EventMachine初始化工作得很好,但我想更好地理解代码。正如您在下面的代码片段中看到的那样,我们的初始化程序会检查乘客,然后在重新启动EventMachine之前检查它是否是fork进程。ifdefined?(PhusionPassenger)PhusionPassenger.on_event(:starting_worker_process)do|forked|#forpassenger,weneedtoavoidorphanedt

ruby - 如果超过 5 秒,如何退出使用 Ruby 运行的进程?

我正在用Ruby实现一个检查系统。它运行具有不同测试的可执行文件。如果解决方案不正确,则可能需要很长时间才能完成某些严格的测试。这就是为什么我想将执行时间限制为5秒。我正在使用system()函数来运行可执行文件:system("./solution");.NET有一个很棒的WaitForExit()方法,那么Ruby呢?有没有办法将外部进程的执行时间限制为5秒?谢谢 最佳答案 您可以使用标准超时库,如下所示:require'timeout'Timeout::timeout(5){system("./solution")}这样您就不

ruby-on-rails - 多线程 rake 任务

我正在编写一个rake任务,它会由Whenever每分钟(将来可能每30秒)调用一次,并且它会联系一个轮询API端点(我们数据库中的每个用户)。显然,这样单线程运行效率不高,但是多线程有可能吗?如果没有,是否有一个好的基于事件的HTTP库可以完成这项工作? 最佳答案 I'mwritingaraketaskthatwouldbecalledeveryminute(possiblyevery30secondsinthefuture)byWhenever注意Rails启动时间,最好使用fork模型,例如Resque或Sidekiq,Res

ruby - Ruby中子进程的流输出

我希望能够在Ruby中流式传输子进程的输出例如p`pinggoogle.com`我想立即看到ping响应;我不想等待流程完成。 最佳答案 您可以执行以下操作而不是使用反引号:IO.popen('pinggoogle.com')do|io|io.each{|s|prints}end干杯! 关于ruby-Ruby中子进程的流输出,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/8732